草庐IT

C++ 和迭代器失效

全部标签

c++ - 将空范围(相同的迭代器)传递给 STL 算法是否会导致定义的行为?

考虑以下几点:std::vectorvec(1);//vectorhasoneelementstd::fill(vec.begin(),vec.begin(),42);std::fill(vec.begin()+1,vec.end(),43);std::fill(vec.end(),vec.end(),44);上面所有的std::fill用法都会导致定义的行为吗?我能保证vec将保持不变吗?我倾向于认为"is",但我想确保标准允许这种用法。 最佳答案 不,如果不会导致未定义的行为。该标准在24.1/7中定义了空迭代器范围,并且没有任

c++ - 迭代 std::map<X,std::vector<Y>> 并对 vector 进行排序

遍历std::map>时,我可以对vector进行排序,还是可以使迭代器无效?也就是说,下面的代码可以吗?typedefstd::map>Map;Mapm;for(Map::iteratorit=m.begin();it!=m.end();++it){std::sort(it->second.begin(),it->second.end());} 最佳答案 您的代码没问题。map中的迭代器只有在您从map中删除元素时才会失效。修改STL容器的元素永远不会使该容器的迭代器失效,只会对容器本身进行操作,例如删除或有时添加元素。

c++ - 按照预期的方式使用迭代器、ifstream、ofstream

我有一个包含一堆单词的txt文件,每行一个。我需要阅读这个文件并将每个单词放在一个列表中然后用户将能够修改此列表完成编辑后,程序会将修改后的列表写入新文件。由于它是面向对象的C++,我将有两个类,一个用于读取/写入文件,一个用于编辑/修改列表和用户。考虑到这种方法,这是我在第一个类中的阅读功能:boolFileMgr::readToList(list&l){if(!input.is_open())returnfalse;stringline;while(!input.eof()){getline(input,line);l.push_back(line);}returntrue;}请记

c++ - 使用带嵌套 vector 的迭代器的意外行为

此示例程序获取一个迭代器,该迭代器指向包含在另一个vector中的一个vector的元素。我将另一个元素添加到包含vector中,然后打印出先前获得的迭代器的值:#include#includeintmain(intargc,charconst*argv[]){std::vector>foo(3,std::vector(3,1));std::vector::iteratorfoo_it=foo[0].begin();std::cout(3,2));std::cout由于对应于foo_it的vector没有被修改,我希望迭代器仍然有效。但是,当我运行此代码时,我得到以下输出(也在ideo

C++ STL vector 迭代器与索引访问和线程安全

我正在迭代一个STLvector并从中读取值。还有另一个线程可以更改此vector。现在,如果另一个线程从vector中插入或删除元素,它会使迭代器无效。不使用涉及的锁。我选择通过索引(方法1)代替迭代器(方法2)访问容器是否使其线程安全?性能怎么样?structA{inti;intj;};方法一:size_ts=v.size();//vcontainspointerstoobjectsoftypeAfor(size_ti=0;ii++;}方法二:std::vector::iteratorbegin=v.begin();std::vector::iteratorend=v.end();

c++ - 从 lambda 访问 for_each 迭代器

是否可以访问std::for_each迭代器,这样我就可以使用lambda从std::list中删除当前元素(如下所示)typedefstd::shared_ptrEventPtr;std::listEventQueue;EventTypeevt;...std::for_each(EventQueue.begin(),EventQueue.end(),[&](EventPtrpEvent){if(pEvent->EventType()==evt.EventType())EventQueue.erase(???Iterator???);});我读过关于使用[](typenameT::va

c++ - 如何使迭代器成为 "automatically dereferenced"?

假设我有这样的东西:classCollection{private:typedefstd::vector>::iteratorIterator;std::vector>data_;public:Iteratorbegin(){returndata_.begin()}Iteratorend(){returndata_.end()}}当我使用Collection::Iterator例如,我需要取消引用它一次,以获得std::shared_ptr对象并再次获得Something对象。但是如果我想制作std::shared_ptr只是一个实现细节,在一次取消引用之后,我应该得到一个Someth

c++ - 如何通过 C++ std::set 尽早结束迭代?

C++我有以下迭代循环:for(it=container.begin();it!=container.end();++it){//mycodehere}我想提前结束这个迭代1元素。我已经尝试了以下但它没有编译:for(it=container.begin();it!=container.end()-1;++it){//subtract1//mycodehere}如何做到这一点?谢谢。 最佳答案 您可以在std::prev(s.end())之前迭代一个,其中s是您的集合,注意容器可能是空:#include//forstd::preva

关于最近VSCode的Python代码格式化失效问题的解决办法

隔了一段时间再次打开VSCode写Python脚本,Python扩展弹出一条警告查看日志输出发现Python的代码格式化设置发生了变化简单来说就是Python扩展已经将原有的默认代码格式化工具"ms-python.python"弃用,格式化功能已移交到单独的格式化工具扩展。所有以"python.linting"开头的设置都已被弃用,需要自行安装yapf、black等格式化工具。下面我以yapf为例,重新设置格式化工具。首先在扩展商店搜索yapf扩展并安装详情里已经写了设置方法,打开设置,在settings.json文件里修改,找到[Python]下的"editor.defaultFormatt

c++ - 从指针或引用获取迭代器

我想知道是否可以通过仅访问容器内的对象来获得容器内对象的迭代器(例如std::vector),例如通过引用(这意味着我们可以使用&运算符访问指向它的指针)。例如,通常我们将迭代器声明为std::vector::iterator=vec.begin();或std::vector::iterator=next(vec.begin(),idx);但在第一个示例中,我们很可能要按顺序遍历容器,而在第二个示例中,我们知道所需对象的索引。我想知道我们是否可以在不知道对象驻留在容器中的哪个索引的情况下获得对象的迭代器,但如果我们确实有一个引用或指向它的指针,如上所述。似乎已经有人问过这个问题了her